草庐IT

php - SQL 插入 Auto_Increment 列

全部标签

ruby - 在 Ruby 中的正则表达式匹配之前插入字符串的好方法

执行此操作的好方法是什么?似乎我可以结合使用几种不同的方法来实现我想要的,但我可能忽略了一种更简单的方法。例如,PHP函数preg_replace将执行此操作。Ruby中有类似的东西吗?我打算做的事情的简单例子:orig_string="alldogsgotoheaven"string_to_insert="nice"regex=/dogs/end_result="allnicedogsgotoheaven" 最佳答案 可以使用Ruby的“gsub”来完成,如下所示:http://railsforphp.com/2008/01/17

sql - 在 Rails 准备语句语法中使用 WHERE IN

假设我有一个id数组(从客户端接收):myArray=[1,5,19,27]我想返回该列表中(次要)id的所有项目。在SQL中这将是:SELECT*FROMItemsWHEREidIN(1,5,19,27)我知道我可以:Item.where(id:[1,5,9,27]),然而,将其添加到的查询使用准备语句语法的时间越长Item.where('myAttrib=?ANDmyOtherAttrib?ANDmyThirdAttrib=?',myVal[0],myVa[1],myVal[2])考虑到这一点,我想要的是:Item.where('idIN?',myArray)但是,这会产生语法错误

sql - 不同的加入 Rails

视频有很多事件我正在尝试获取所有在未来安排了事件的视频。我已经有了这个:named_scope:scheduled_in_future,:joins=>:event,:conditions=>["event.scheduled_start>?ANDevent.status=?",Time.now.to_i,'PENDING']这行得通,但如果同一个视频在未来有多个事件,它会给我重复的视频记录。当然,我可以遍历数组并清除重复项,但必须有一种SQL方法才能做到这一点。我尝试添加一个:select=>"DISTINCT(video.id)"但它只返回ID字段而不是整个记录。

sql - 如何使用 Arel 正确地向带有 'or' 和 'and' 子句的 SQL 查询添加括号?

我正在使用RubyonRails3.2.2,我想生成以下SQL查询:SELECT`articles`.*FROM`articles`WHERE(`articles`.`user_id`=1OR`articles`.`status`='published'OR(`articles`.`status`='temp'AND`articles`.`user_id`IN(10,11,12,)))通过使用Arel这样Article.where(arel_table[:user_id].eq(1).or(arel_table[:status].eq("published")).or(arel_tab

sql - Rails 3 Sum 两个领域的产品

我需要计算我的Rails3应用中两个字段的乘积之和(即相当于Excel的sumproduct函数)。Rails中是否有一种方法可以帮助解决这个问题?如果没有,那么使用自定义sql的Rails代码是什么?例如,酒店有很多房间。房间具有sqft(平方英尺)、数量(该尺寸)和hotel_id的属性。我想计算给定酒店中所有房间的总平方英尺。在SQL中,对于Hotel.id=8,我相信以下语句会起作用:selectsum(rooms.sqft*rooms.quantity)asSumSqftfromroomsinnerjoinhotelsonrooms.hotel_id=hotels.idwhe

sql - 在 Rails 中进行计数的正确方法是什么?

我有一个包含以下许多代码片段的Rails应用程序:Ouractivecommunityof我的问题是,这是计算观看次数的正确方法吗?看起来很“肮脏”,有没有更粗鲁的方法来计算?我可能在考虑命名范围,但我只是想确保这些类型的东西不会对性能产生更大的影响。谢谢你, 最佳答案 您不需要名称范围来执行计数。Account.where(:admin=>false).count但是命名作用域是使您的代码更具可重用性的绝佳方式。命名范围不会对您的应用程序产生任何明显的性能影响。 关于sql-在Rail

ruby - 如何在 Ruby 数组的所有元素之间插入一个新元素?

我有一个数组,想在所有元素之间插入一个新元素,类似于join方法。例如,我有[1,[],"333"]我需要的是[1,{},[],{},"333"]请注意,在所有元素之间插入了一个新的空散列。编辑:目前我拥有的是:irb(main):028:0>a=[1,[],"333"]=>[1,[],"333"]irb(main):029:0>a=a.inject([]){|x,y|x[1,{},[],{},"333",{}]irb(main):030:0>a.pop=>{}irb(main):031:0>a=>[1,{},[],{},"333"]irb(main):032:0>我想知道最好的方法。

ruby-pg 在插入之前清理数据

这里是Ruby新手。我正在尝试插入此字符串“LadyArabella'sScandalo...”我正在使用ruby​​-pg来执行此操作。但是由于单引号我有错误,我怎样才能清理这个字符串并删除所有html标签?是否有内置函数? 最佳答案 您可以使用escape_string正确转义你的单引号:db=PG.connect(...)db.exec("insertintot(...)values('#{db.escape_string(str)}',...)")或使用prepare和exec_prepared改为使用准备好的语句:db.p

ruby - 如何在 Ruby 中插入或更新之前转义字符串

在ruby​​中,ActiveRecord不提供更新和插入sql的动态绑定(bind),当然我可以使用原始sql,但是需要保持连接,所以我想知道是否有更简单的方法在执行之前转义更新或插入sql像下面的代码:ActiveRecord::Base.connection.insert(sql)我想我可以用gsub写代码,但我知道是否有现成的方法来做。 最佳答案 在Rails>=3.2.5中,以下对我有用:evil_input='"\';%#{}\"foo'ActiveRecord::Base.connection.quote(evil_i

ruby-on-rails - Rails 还是 Sinatra? PHP程序员入门学习哪个好?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。我使用PHP的时间太长了,对它感到厌倦了。我也想学习一门新语言。我一直在使用Ruby并且喜欢它。我必须在Rails和Sinatra之间做出选择,那么您会推荐哪一个?Sinatra真的不能用来构建复杂的应用程序,它只能用于简单的应用程序吗?